## Systemy komputerowe

Lista zadań nr 8

Na zajęcia 18 – 29 kwietnia 2019

UWAGA! W trakcie prezentacji należy zdefiniować pojęcia oznaczone wytłuszczoną czcionką.

**Zadanie 1.** Opisz różnice między **przerwaniem sprzętowym** (ang. *hardware interrupt*), **wyjątkiem procesora** (ang. *exception*) i **pułapką** (ang. *trap*). Dla każdego z nich podaj co najmniej trzy przykłady zdarzeń, które je wyzwalają. W jakim scenariuszu wyjątek procesora nie oznacza błędu czasu wykonania programu? Kiedy pułapka jest generowana w wyniku prawidłowej pracy programu?

**Zadanie 2.** Opisz mechanizm **obsługi przerwań** bazujący na **wektorze przerwań** (ang. *interrupt vector table*). Co robi procesor przed pobraniem pierwszej instrukcji **procedury obsługi przerwania** (ang. *interrupt handler*) i po natrafieniu na instrukcję powrotu z przerwania? Dlaczego procedura obsługi przerwania powinna być wykonywana w **trybie nadzorcy** i używać odrębnego stosu?

**Zadanie 3.** Opisz następujące mechanizmy dostępu do urządzeń I/O: **Programowane wejście/wyjście** (ang. *Programmed I/O*), **Wejście/wyjście sterowane przerwaniami** (ang. *Interrupt-driven I/O*) oraz **Bezpośredni dostęp do pamięci** (ang. *Direct Memory Access (DMA)*). Które z nich wykorzystują przerwania?

**Zadanie 4.** Wzorując się na slajdach do wykładu "Virtual Memory Systems" (strony 10–21) powtórz proces **translacji adresów** i adresowania pamięci podręcznej dla adresów: 0x027c, 0x03a9 i 0x0040 zakładając poniższy stan **TLB**, pamięci podręcznej i **tablicy stron**.



**Zadanie 5.** W tym zadaniu będziemy analizowali w jaki sposób system operacyjny musi aktualizować **tablicę stron** wraz z kolejnym dostępami do pamięci głównej. Załóż, że strony są wielkości 4KiB, TLB jest **w pełni asocjacyjne** z zastępowaniem LRU. Jeśli potrzebujesz **wtoczyć** (ang. *swap-in*) stronę z dysku użyj następnego numeru **ramki** (ang. *page frame*) większego od największego istniejącego w tablicy stron.

Dla poniższych danych podaj ostateczny stan TLB i tablicy stron po wykonaniu wszystkich dostępów do pamięci. Dla każdej operacji dostępu do pamięci wskaż czy było to trafienie w TLB, trafienie w tablicę stron, czy też **błąd strony**.

| VPN | Valid? | PPN  |
|-----|--------|------|
| 0   | 1      | 5    |
| 1   | 0      | dysk |
| 2   | 0      | dysk |
| 3   | 1      | 6    |
| 4   | 1      | 9    |
| 5   | 1      | 11   |
| 6   | 0      | dysk |
| 7   | 1      | 4    |
| 8   | 0      | dysk |
| 9   | 0      | dysk |
| 10  | 1      | 3    |
| 11  | 1      | 12   |
| 12  | 0      | brak |

| Valid? | Tag | LRU | PPN |
|--------|-----|-----|-----|
| 1      | 11  | 0   | 12  |
| 1      | 7   | 1   | 4   |
| 1      | 3   | 2   | 6   |
| 0      | 4   | 3   | 9   |

| Początkowy sta | an TLB |
|----------------|--------|

| Adres |
|-------|
| 4669  |
| 2227  |
| 13916 |
| 34587 |
| 48870 |
| 12608 |
| 49225 |

Ciąg dostępów do pamięci

Początkowy stan tablicy stron

**Zadanie 6.** Niech system posługuje się 32-bitowymi adresami wirtualnymi, rozmiar strony ma 4KiB, a rozmiar wpisu tablicy stron zajmuje 4 bajty. Dla procesu, który łącznie używa 1GiB swojej przestrzeni adresowej podaj rozmiar tablicy stron: (a) jednopoziomowej, (b) dwupioziomowej, gdzie katalog tablicy stron ma 1024 wpisy. Dla drugiego przypadku – jaki jest maksymalny i minimalny rozmiar tablicy stron?

**Zadanie 7.** Na wykładzie przyjęliśmy, że translacja adresów jest wykonywana przed dostępem do pamięci podręcznej. Taki schemat określa się mianem pamięci podręcznej **indeksowanej** i **znakowanej adresami fizycznymi** (ang. *physically-indexed, physically-tagged*). Wyjaśnij jak zrównoleglić dostęp do TLB i pamięci podręcznej, stosując schemat pamięci indeksowanej wirtualnie i znakowanej fizycznie.

Wskazówka: Posłuż się slajdem 34 do wykładu "Virtual Memory: Systems", ale wytłumacz to szczegółowo!

**Zadanie 8.** Celem zwiększenia wydajności dostępów do pamięci architekt procesora decyduje się na użycie schematu pamięci indeksowanej i znakowanej adresami wirtualnymi (ang. *virtually-indexed*, *virtually-tagged*). Wyjaśnij jak w takim przypadku może zamanifestować się problem homonimów i synonimów<sup>1</sup>?

Wskazówka: Można posłużyć się rysunkiem 4.2 z książki "Memory Systems: Cache, DRAM, Disk".

**Zadanie 9 (bonus).** Na podstawie §31.1.4 książki "Memory Systems: Cache, DRAM, Disk" wyjaśnij jak przebiega mechanizm translacji adresów bazujący na odwróconej tablicy stron stosowany w architekturze PowerPC. Wymień wady i zalety tego rozwiązania w porównianiu do wielopoziomowej tablicy stron.

<sup>1</sup>https://en.wikipedia.org/wiki/CPU\\_cache\#Homonym\\_and\\_synonym\\_problems